#include <stdio.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <unistd.h>

int main()
{
    int fd = open("log.txt", O_WRONLY | O_CREAT | O_TRUNC, 0666);

    if(fd < 0)
    {
        perror("open");
        return 1;
    }

    //本来1号位置的指针，被覆盖成了3号位置的指针
    int ret = dup2(fd, 1); //fd = 3, 1
    if(ret > 0) close(fd);

    printf("ret : %d\n", ret);

    //本来应该要往显示器打印，最终却变成了向指定文件打印 -- 重定向的原理
    fprintf(stdout, "打开文件成功, fd: %d\n", fd);

    //暂时不做解释，后面再说 -- 和缓冲区有关
    fflush(stdout);
    close(fd);

    return 0;
}

